package com.bys.admin.ai.entity;

import lombok.*;
import java.util.*;
import java.time.LocalDateTime;
import java.math.BigDecimal;
import java.time.LocalDateTime;
import java.time.LocalDateTime;
import com.baomidou.mybatisplus.annotation.*;
import com.bys.config.BaseEntity;

/**
 * AI Chat 对话 entity
 *
 * @author 系统管理员
 */
@TableName("ai_chat")
@KeySequence("ai_chat_seq") // 用于 Oracle、PostgreSQL、Kingbase、DB2、H2 数据库的主键自增。如果是 MySQL 等数据库，可不写。
@Data
@EqualsAndHashCode(callSuper = true)
@ToString(callSuper = true)
@Builder
@NoArgsConstructor
@AllArgsConstructor
public class Chat extends BaseEntity {
    public static final String TITLE_DEFAULT = "新对话";

    /**
     * 用户Id
     */
    private Long userId;
    /**
     * 对话标题
     */
    private String title;
    /**
     * 是否置顶
     */
    private Boolean pinned;
    /**
     * 置顶时间
     */
    private LocalDateTime pinnedTime;
    /**
     * 角色id
     */
    private Long roleId;
    /**
     * 知识库id
     */
    private Long knowledgeId;
    /**
     * 模型id
     */
    private Long modelId;

    /**
     * 模型标志
     */
    private String model;
    /**
     * 角色设定
     */
    private String systemMessage;
    /**
     * 温度参数
     */
    private BigDecimal temperature;
    /**
     * 单条回复的最大 Token 数量
     */
    private Integer maxTokens;
    /**
     * 上下文的最大 Message 数量
     */
    private Integer maxContexts;

}